Figure 1 
Modified SSA-corwersion process 
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Overall compiler control flow 
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Program representation 
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Figure 4 

Placement of read/write-backs for the SSAform of *x, (*x)'1 
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Figure 8 
Example source program 

This short C program is used to illustrate the invention: 

extern int g 0 . h ( ) , i ( ) , x; 
int foo (int *p) 

{ 

(*p) ++; 

if (*P > 1 0) 
{ 



g(); 




no; 




if (x> 


5) 


gO 




if (x> 


3) 


i(); 




else 




X = 


*p; 


*P = 5 





} 

return *p; 

} 

Here's the same program converted to a slightly more primitive form 

int foo (int *p) 
{ 

blockl : 

*p := *p +1; 

if (*P <= 10) 
goto block8; 
block2: 

gO; 
ho ; 

if (x <= 5) 
goto block4; 
block3: 

gO; 

block4: 
if (x > 3) 

goto block6; 
blocks : 

x:= *p; 

goto block7; 
block6 : 

i(); 
block7 : 

*p := 5; 
block8: 
return *p; 

} 



Figure 9 

SSA converted program, with simple 
implementation of read-backs : 



The following is psuedo-C, augmented with the * phi' operation, where 
RESULT = phi (blockl: VAL1 , blockN:VALN) 

means assign VAL1 to RESULT if control-flow comes from blockl ' , and 
similarly so on for each value of N. 

The extra variables "pvN", where N is an integer, are SSA versions 
of *P, and are in fact local variables, not dereferences of p. 

Intfoo (int *p) t 
{ 

int pvl, pv2 , pv3 , pv4, pv5, pv6; 

blockl ; 

pvl = *P + 1 ; 

if (pvl <= 10) 
goto block8; 
block2: 

*P = pvl; /* This writes-back PV1 to *P. */ 

gO; 

pv2 = *P; /* This reads-back *P into PV2. */ 

*P = pv2; /* This writes-back PV2 to *P. */ 
h(); 

pv3 = *P; /* This reads-back *P into PV3 */ 
if (x <= 5) 
goto block4; 
block3: 

*p = pv3; /* This writes-back PV4 to *p, */ 

g(); 

pv4= *p; /*This reads-back *p into PV4. */ 

block4: 

pv5 = phi (block3: pv4, block2: pv3) 

if (x > 3) 
goto block6; 
blocks: 

gota block7; 
block6; 

i(); 
block7: 

x = phi (block6: x, blocks: pvS); 
block8: 

pv6 = phi (blockl : pvl , block7: 5); 

*P = pv6; /* This writes-back PV6 to *P. */ 

return pv6; 

} 
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SSA converted program, 
with the implementation of read-backs described in this patent 



I* This writes-back pv1 to *P. */ 



int foo (int *p) 
{ 

int pv1 , pv2, pv3; 

blockl : 
pv1 = *p +1; 
if (pvl<= 10) 
goto block8; 

block2; 
*p = pv1 ; 

g(); 
h(); 
if (x <= 5) 
goto block4; 

block3; 

gO; 

block4: 
pv2 = *p; 
if (x > 3) 
goto block6; 

blocks; 
goto block7; 

block6: 
i(); 



black7 : 

x = phi (block6 : x, block5 : pv2) ; 
block8: 

pv3 = phi (blockl: pv1, block7: 5); 

*P = pv3; /*This writes-back PV3 to *P */ 



/* This reads-back *p into pv2, */ 
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return pv3; 



Figure 11 

Register-alloced and SSA-u neon verted program 



using BBA-form requires having a good register allocator that will 
merge variables where possible, as it tends to generate a lot of 
variables with short lifetimes. We assume that here. 

int foo (int *p) 
{ 

int pv; 

blockl ; 

pv = *p + 1 ; 
if(pv<=10) 
goto block8; 

block2: 

'P = pv; /* This writes-back pv to *P. */ 

g(); 
h(); 
if (x <= 5) 
goto block4; 

block3 : 

g(); 

block4 : 
if (x > 3) 
goto block6; 

blocks: 
x=*p; 
goto block7; 

block6: 
i(); 

block7: 
pv=5; 

block8: 

*P= pv /* This writes-back PV to *P. */ 

return pv; 

} 
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Figure 12 
Original SSA-conversion process 
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